<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .father {
            width: 200px;
            height: 200px;
            background-color: orange;
            text-align: center;
        }

        .son {
            width: 100px;
            height: 100px;
            background-color: purple;
            margin-left: 50px;
        }
    </style>
</head>
<body>
    <div class="father">
        <div class="son">

        </div>
    </div>
    <script>
        // dom 事件流 三个阶段
        // 1. JS 代码中只能执行捕获或者冒泡其中的一个阶段。
        // 2. onclick 和 attachEvent（ie） 只能得到冒泡阶段。
        // 3. 捕获阶段 如果addEventListener 第三个参数是 true 那么则处于捕获阶段 
        // document -> html -> body -> father -> son
        var f_div = document.querySelector('.father');
        var s_div = document.querySelector('.son');
        // f_div.addEventListener('click', function() {
        //     console.log('father 监听点击方法');
        // }, true);
        // s_div.addEventListener('click',function(){
        //     console.log('son 监听点击方法');
        // }, true);
        // document.addEventListener('click', function(){
        //     console.log('document 监听点击方法');
        // },true);

        //冒泡阶段
        f_div.addEventListener('click', function() {
            console.log('father 监听点击方法');
        });
        s_div.addEventListener('click',function(){
            console.log('son 监听点击方法');
        });
        document.addEventListener('click', function(){
            console.log('document 监听点击方法');
        });
    </script>
</body>
</html>